<template>
  <div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;">序号：</div><el-input size="mini"
        style="width: 60px;margin-right: 20px;" v-model="nodeModel.sort"></el-input>
      <div style="flex-shrink: 0;font-size: 14px;">是否显示：</div><el-switch v-model="nodeModel.isShow" :active-value="true"
          :inactive-value="false" active-color="#13ce66" inactive-color="#999999"></el-switch>
        <div style="margin-left: 20px;">
          <el-button @click="selectTemplate" size="mini">选用模版</el-button>
        </div>
    </div>
    <div style="flex-shrink: 0;font-size: 14px;margin-left: 10px;font-size: 16px;font-weight: bold;margin-top: 20px;">
      容器属性：</div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;">背景色：</div>
      <el-input size="mini" style="width: 100px;" v-model="nodeModel.configDict.componentStyle.background"></el-input>
      <el-color-picker v-model="nodeModel.configDict.componentStyle.background"></el-color-picker>
    </div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">排列方向：</div>
      <el-radio v-model="nodeModel.configDict.componentStyle.flex_direction" label='row'>左右</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.flex_direction" label='column'>上下</el-radio>
    </div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">换行类型：</div>
      <el-radio v-model="nodeModel.configDict.componentStyle.flex_wrap" label='wrap'>换行</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.flex_wrap" label='nowrap'>不换行</el-radio>
    </div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">主轴对齐方式：</div>
      <el-radio v-model="nodeModel.configDict.componentStyle.justify_content" label='flex-start'>起点对齐</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.justify_content" label='flex-end'>终点对齐</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.justify_content" label='center'>居中对齐</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.justify_content" label='space-between'>两端对齐</el-radio>
    </div>
    <div class="row">
      <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">交叉轴对齐方式：</div>
      <el-radio v-model="nodeModel.configDict.componentStyle.align_items" label='flex-start'>起点对齐</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.align_items" label='flex-end'>终点对齐</el-radio>
      <el-radio v-model="nodeModel.configDict.componentStyle.align_items" label='center'>居中对齐</el-radio>
    </div>
    <div class="column">
      <jcSlider title="宽：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.width"
        :min="10" :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="上外边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.marginTop" :min="0"
          :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="下外边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.marginBottom"
          :min="0" :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="左外边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.marginLeft" :min="0"
          :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="右外边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.marginRight"
          :min="0" :max="750" show-input input-size="mini"></el-slider></jcSlider>
    </div>
    <div class="column">
      <jcSlider title="上内边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.paddingTop" :min="0"
          :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="下内边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.paddingBottom"
          :min="0" :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="左内边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.paddingLeft"
          :min="0" :max="750" show-input input-size="mini"></el-slider></jcSlider>
      <jcSlider title="右内边距："><el-slider slot="slider" v-model="nodeModel.configDict.componentStyle.paddingRight"
          :min="0" :max="750" show-input input-size="mini"></el-slider></jcSlider>
    </div>
    <!-- 图文排列样式 -->
    <div style="border: 1px solid #eee;margin-top: 10px;padding: 10px 0;padding-right: 10px;">
      <div style="flex-shrink: 0;font-size: 14px;margin-left: 10px;font-size: 16px;font-weight: bold;">项目属性：</div>
      <div class="row">
        <div style="flex-shrink: 0;font-size: 14px;">背景色：</div><el-input size="mini" style="width: 100px;"
          v-model="nodeModel.configDict.itemStyle.background"></el-input>
        <el-color-picker v-model="nodeModel.configDict.itemStyle.background"></el-color-picker>
      </div>
      <div class="row">
        <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">排列方向：</div>
        <el-radio v-model="nodeModel.configDict.itemStyle.flex_direction" label='row'>左右</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.flex_direction" label='column'>上下</el-radio>
      </div>
      <div class="row">
        <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">主轴对齐方式：</div>
        <el-radio v-model="nodeModel.configDict.itemStyle.justify_content" label='flex-start'>起点对齐</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.justify_content" label='flex-end'>终点对齐</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.justify_content" label='center'>居中对齐</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.justify_content" label='space-between'>两端对齐</el-radio>
      </div>
      <div class="row">
        <div style="flex-shrink: 0;font-size: 14px;margin-right: 20px;">交叉轴对齐方式：</div>
        <el-radio v-model="nodeModel.configDict.itemStyle.align_items" label='flex-start'>起点对齐</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.align_items" label='flex-end'>终点对齐</el-radio>
        <el-radio v-model="nodeModel.configDict.itemStyle.align_items" label='center'>居中对齐</el-radio>
      </div>
      <div class="column">
        <jcSlider title="项目宽：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.itemStyle.width"
            :min="10" :max="750" show-input input-size="mini"></el-slider></jcSlider>
        <jcSlider title="内上边距：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.paddingTopForItem" :min="0" :max="200" show-input
            input-size="mini"></el-slider></jcSlider>
        <jcSlider title="内下边距：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.paddingBottomForItem" :min="0" :max="200" show-input
            input-size="mini"></el-slider></jcSlider>
        <jcSlider title="内左边距：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.paddingLeftForItem" :min="0" :max="200" show-input
            input-size="mini"></el-slider></jcSlider>
      </div>
      <div class="column">
        <jcSlider title="水平间距：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.marginLeftForItem" :min="0" :max="100" show-input
            input-size="mini"></el-slider></jcSlider>
        <jcSlider title="垂直间距：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.marginBottomForItem" :min="0" :max="100" show-input
            input-size="mini"></el-slider></jcSlider>
      </div>
      <div class="column">
        <jcSlider title="图片宽：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.widthForCover1" :min="10" :max="750" show-input
            input-size="mini"></el-slider></jcSlider>
        <jcSlider title="图片高：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.heightForCover1" :min="10" :max="2000" show-input
            input-size="mini"></el-slider></jcSlider>
        <jcSlider title="图片圆角：" :titleWidth="80"><el-slider slot="slider"
            v-model="nodeModel.configDict.itemStyle.borderRadiusForCover1" :min="0" :max="500" show-input
            input-size="mini"></el-slider></jcSlider>
      </div>
      <div class="column" style="margin-top: 10px;align-items: flex-start;">
        <div style="flex-shrink: 0;font-size: 14px;">文本区域内边距：</div>
        <div>
          <jcSlider title="上：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.itemStyle.paddingTopForFlex2" :min="0"
              :max="200" show-input input-size="mini"></el-slider></jcSlider>
          <jcSlider title="下：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.itemStyle.paddingBottomForFlex2"
              :min="0" :max="200" show-input input-size="mini"></el-slider></jcSlider>
          <jcSlider title="左：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.itemStyle.paddingLeftForFlex2"
              :min="0" :max="200" show-input input-size="mini"></el-slider></jcSlider>
          <jcSlider title="右：" :titleWidth="80"><el-slider slot="slider" v-model="nodeModel.configDict.itemStyle.paddingRightForFlex2"
              :min="0" :max="200" show-input input-size="mini"></el-slider></jcSlider>
        </div>
      </div>
      <!-- 标题样式 -->
      <div style="background-color: #eee;width: 600px;height: 1px;margin-left: 20px;margin-top: 10px;"></div>
      <div class="column">
        <div style="flex-shrink: 0;font-size: 14px;font-weight: bold;">标题样式：</div>
        <div class="row">
          <div style="flex-shrink: 0;font-size: 14px;">是否显示：</div>
          <el-radio v-model="nodeModel.configDict.itemStyle.isShowForText1" :label='true'>是</el-radio>
          <el-radio v-model="nodeModel.configDict.itemStyle.isShowForText1" :label='false'>否</el-radio>
          <div style="flex-shrink: 0;font-size: 14px;">是否加粗：</div>
          <el-radio v-model="nodeModel.configDict.itemStyle.fontweightForText1" label='bold'>是</el-radio>
          <el-radio v-model="nodeModel.configDict.itemStyle.fontweightForText1" label=''>否</el-radio>
        </div>
        <div class="row" style="margin-left: 50px;">
          <div style="flex-shrink: 0;font-size: 14px;">颜色：</div>
          <el-input size="mini" style="width: 100px;" v-model="nodeModel.configDict.itemStyle.colorForText1"></el-input>
          <el-color-picker v-model="nodeModel.configDict.itemStyle.colorForText1"></el-color-picker>
        </div>
        <div class="column">
          <jcSlider title="上边距：" :titleWidth="70"><el-slider slot="slider"
              v-model="nodeModel.configDict.itemStyle.marginTopForText1" :min="0" :max="100" show-input
              input-size="mini"></el-slider></jcSlider>
          <jcSlider title="字体大小：" :titleWidth="70"><el-slider slot="slider"
              v-model="nodeModel.configDict.itemStyle.fontsizeForText1" :min="10" :max="100" show-input
              input-size="mini"></el-slider></jcSlider>
        </div>
      </div>
      <!-- 副标题样式 -->
      <div style="background-color: #eee;width: 600px;height: 1px;margin-left: 20px;margin-top: 10px;"></div>
      <div class="column">
        <div style="flex-shrink: 0;font-size: 14px;font-weight: bold;">副标题样式：</div>
        <div class="row">
          <div style="flex-shrink: 0;font-size: 14px;">是否显示：</div>
          <el-radio v-model="nodeModel.configDict.itemStyle.isShowForText2" :label='true'>是</el-radio>
          <el-radio v-model="nodeModel.configDict.itemStyle.isShowForText2" :label='false'>否</el-radio>
          <div style="flex-shrink: 0;font-size: 14px;">是否加粗：</div>
          <el-radio v-model="nodeModel.configDict.itemStyle.fontweightForText2" label='bold'>是</el-radio>
          <el-radio v-model="nodeModel.configDict.itemStyle.fontweightForText2" label=''>否</el-radio>
        </div>
        <div class="row" style="margin-left: 50px;">
          <div style="flex-shrink: 0;font-size: 14px;">颜色：</div>
          <el-input size="mini" style="width: 100px;" v-model="nodeModel.configDict.itemStyle.colorForText2"></el-input>
          <el-color-picker v-model="nodeModel.configDict.itemStyle.colorForText2"></el-color-picker>
        </div>
        <div class="column">
          <jcSlider title="上边距：" :titleWidth="70"><el-slider slot="slider"
              v-model="nodeModel.configDict.itemStyle.marginTopForText2" :min="0" :max="100" show-input
              input-size="mini"></el-slider></jcSlider>
          <jcSlider title="字体大小：" :titleWidth="70"><el-slider slot="slider"
              v-model="nodeModel.configDict.itemStyle.fontsizeForText2" :min="10" :max="100" show-input
              input-size="mini"></el-slider></jcSlider>
        </div>
      </div>
    </div>
    <!-- 图文列表内容区域 -->
    <div style="border: 1px solid #eee;padding: 10px;margin-top: 10px;">
      <div style="display: flex;flex-direction: row;margin-bottom: 10px;position: relative;margin-top: 20px;"
        v-for="(item, index) in nodeModel.configDict.itemList" :key='index'>
        <el-image style="width: 100px; height: 100px;flex-shrink: 0;" :src="item.coverUrl" fit="cover"></el-image>
        <div style="width: 100%;">
          <div style="margin-left: 10px;display: flex;flex-direction: row;">
            <div style="display: flex;flex-direction: row;align-items: center;">
              <div style="flex-shrink: 0;">序号：</div><el-input style="width: 60px;" v-model="item.sort"></el-input>
            </div>
            <div style="display: flex;flex-direction: row;align-items: center;margin-left: 10px;">
              <div style="flex-shrink: 0;">标题：</div><el-input v-model="item.text1"></el-input>
            </div>
          </div>
          <div style="margin-left: 10px;display: flex;flex-direction: row;">
            <div style="display: flex;flex-direction: row;align-items: center;margin-left: 10px;">
              <div style="flex-shrink: 0;">副标题：</div><el-input v-model="item.text2"></el-input>
            </div>
          </div>
          <div style="margin-left: 10px;margin-top: 10px;display: flex;flex-direction: row;">
            <div style="width: 100%;"><el-input style="margin-left: 0px;" v-model="item.coverUrl"></el-input></div>
            <custom :model="item" buttonTitle="选择文件"></custom>
          </div>
          <div style="margin-left: 10px;margin-top: 10px;display: flex;flex-direction: row;">
            <div style="width: 100%;"><el-input style="margin-left: 0px;" v-model="item.query"></el-input></div>
            <div><el-button @click="selectRoute(item)">路由参数</el-button></div>
          </div>
        </div>
        <div style="position: absolute;left: -15px;top: -15px;" @click="deleteAdvert(index)"><i
            class="el-icon-circle-close"></i></div>
      </div>
      <div style="width: 100%;"><el-button @click="insertAdvert">添加一个</el-button></div>
    </div>
  </div>
</template>

<script>
import custom from '@/components/jcupload/custom'
import jcSlider from '@/views/interface/composing/components/jc-slider'
export default {
  components: {
    custom,
    jcSlider
  },
  props: {
    nodeModel: {
      type: Object,
      default: res => { }
    }
  },
  data() {
    return {

    }
  },
  methods: {
    insertAdvert() {
      this.$emit('insertAdvert', { name: this.nodeModel.componentModel.name })
    },
    deleteAdvert(index) {
      this.$emit('deleteAdvert', index)
    },
    selectRoute(item) {
      this.$emit('selectRoute', item)
    },
    selectTemplate(){
      this.$emit('selectTemplate')
    },
  }
}
</script>

<style lang="scss" scoped>
@import './commonStyle.scss';
</style>